Complex কুয়েরি এবং Projection কৌশল

Microsoft Technologies - এন্টিটি ফ্রেমওয়র্ক (Entity Framework) LINQ (Language Integrated Query) এবং Entity Framework |
177
177

Entity Framework (EF) এ Complex Queries এবং Projection দুটি গুরুত্বপূর্ণ কৌশল, যেগুলি আপনাকে ডেটাবেস থেকে আরও উন্নত এবং নির্দিষ্ট তথ্য আহরণ করতে সাহায্য করে। এগুলির মাধ্যমে আপনি একাধিক টেবিল থেকে তথ্য সংগ্রহ করতে পারেন, সম্পর্কিত ডেটা ফিল্টার করতে পারেন, এবং প্রয়োজনীয় ডেটাকে কাস্টম ফরম্যাটে রিটার্ন করতে পারেন।


Complex কুয়েরি

Complex Queries বলতে বুঝায় একাধিক শর্ত বা জটিল লজিক ব্যবহার করে ডেটাবেস থেকে তথ্য আহরণ করার প্রক্রিয়া। EF তে আপনি LINQ (Language Integrated Query) ব্যবহার করে সহজেই Complex Queries লিখতে পারেন।

একাধিক টেবিল থেকে ডেটা সংগ্রহ করা

EF তে একাধিক টেবিলের মধ্যে সম্পর্ক থাকে, যেমন One-to-Many বা Many-to-Many সম্পর্ক। আপনি Join ব্যবহার করে একাধিক টেবিল থেকে ডেটা সংগ্রহ করতে পারেন।

উদাহরণ: Users এবং Orders টেবিলের মধ্যে সম্পর্কিত ডেটা নিয়ে একটি জটিল কুয়েরি করা:

var result = from u in context.Users
             join o in context.Orders on u.UserId equals o.UserId
             where u.Age > 25
             select new
             {
                 u.Name,
                 u.Email,
                 o.OrderDate,
                 o.Amount
             };

foreach (var item in result)
{
    Console.WriteLine($"{item.Name} - {item.OrderDate} - {item.Amount}");
}

এখানে, Users এবং Orders টেবিলের মধ্যে Join করা হয়েছে, যেখানে UserId দ্বারা সম্পর্কিত ডেটা ফিল্টার করা হয়েছে এবং Age > 25 এর শর্তে ফলাফল রিটার্ন করা হয়েছে।


Projection কৌশল

Projection একটি কৌশল যা আপনাকে ডেটাবেস থেকে নির্বাচিত ডেটাকে একটি নির্দিষ্ট ফরম্যাটে রূপান্তর করতে সাহায্য করে। সাধারণত এটি Anonymous Types বা DTOs (Data Transfer Objects) তৈরি করার জন্য ব্যবহৃত হয়, যাতে আপনি শুধু প্রয়োজনীয় ফিল্ডগুলো রিটার্ন করেন, সমস্ত কলাম নয়।

Projection এর মাধ্যমে ডেটা রূপান্তর

উদাহরণ: শুধুমাত্র Name এবং Email প্রপার্টি রিটার্ন করা:

var result = from u in context.Users
             where u.Age > 30
             select new
             {
                 u.Name,
                 u.Email
             };

foreach (var item in result)
{
    Console.WriteLine($"Name: {item.Name}, Email: {item.Email}");
}

এখানে, Users টেবিলের Age > 30 শর্তে শুধু Name এবং Email প্রপার্টি রিটার্ন করা হয়েছে, যা ডেটাবেস থেকে অতিরিক্ত কলাম পাওয়ার পরিবর্তে খুবই নির্দিষ্ট তথ্য প্রদান করে।


Complex কুয়েরি এবং Projection একসাথে ব্যবহার করা

আপনি Complex Queries এবং Projection একসাথে ব্যবহার করে আরও কার্যকরী কুয়েরি তৈরি করতে পারেন। যেমন, একাধিক টেবিল থেকে সম্পর্কিত ডেটা সংগ্রহ করার পর শুধুমাত্র প্রয়োজনীয় ডেটা রিটার্ন করা।

উদাহরণ: Users এবং Orders টেবিল থেকে নির্দিষ্ট ডেটা রিটার্ন করা:

var result = from u in context.Users
             join o in context.Orders on u.UserId equals o.UserId
             where u.Age > 25
             select new
             {
                 u.Name,
                 u.Email,
                 TotalOrders = o.Count(),
                 TotalAmountSpent = o.Sum(order => order.Amount)
             };

foreach (var item in result)
{
    Console.WriteLine($"{item.Name} - {item.Email} - {item.TotalOrders} Orders - {item.TotalAmountSpent} Total Spent");
}

এখানে, Users এবং Orders টেবিলের মধ্যে Join করা হয়েছে, এবং Age > 25 শর্তের সাথে সাথে Projection ব্যবহার করে Name, Email, মোট অর্ডারের সংখ্যা এবং মোট পরিমাণের হিসাবও করা হয়েছে।


Eager Loading এবং Projection

EF তে Eager Loading ব্যবহার করে আপনি সম্পর্কিত ডেটা (related data) একত্রে লোড করতে পারেন, যা আপনার কুয়েরির পারফরম্যান্স উন্নত করতে সাহায্য করে। Include মেথড ব্যবহার করে আপনি সম্পর্কিত টেবিলের ডেটা লোড করতে পারেন এবং Projection ব্যবহার করে নির্বাচিত ডেটা রিটার্ন করতে পারেন।

উদাহরণ: Users টেবিলের সাথে সম্পর্কিত Orders টেবিলের ডেটা লোড করা এবং প্রোজেক্ট করা:

var result = context.Users
                    .Where(u => u.Age > 30)
                    .Include(u => u.Orders)
                    .Select(u => new
                    {
                        u.Name,
                        u.Email,
                        Orders = u.Orders.Select(o => new { o.OrderDate, o.Amount })
                    })
                    .ToList();

foreach (var item in result)
{
    Console.WriteLine($"Name: {item.Name}, Email: {item.Email}");
    foreach (var order in item.Orders)
    {
        Console.WriteLine($"Order Date: {order.OrderDate}, Amount: {order.Amount}");
    }
}

এখানে, Eager Loading এর মাধ্যমে Orders সম্পর্কিত ডেটা লোড করা হয়েছে এবং Projection এর মাধ্যমে শুধু প্রয়োজনীয় ফিল্ডগুলো রিটার্ন করা হয়েছে।


Asynchronous LINQ কুয়েরি

Asynchronous কুয়েরি ব্যবহার করলে আপনি UI থ্রেড ব্লক না করে ডেটাবেস থেকে ডেটা আহরণ করতে পারেন। EF Core তে ToListAsync(), FirstOrDefaultAsync(), ইত্যাদি অ্যাসিঙ্ক্রোনাস মেথড ব্যবহার করা যায়।

উদাহরণ:

var result = await context.Users
                           .Where(u => u.Age > 25)
                           .Select(u => new { u.Name, u.Email })
                           .ToListAsync();

foreach (var item in result)
{
    Console.WriteLine($"Name: {item.Name}, Email: {item.Email}");
}

এখানে, অ্যাসিঙ্ক্রোনাস কুয়েরি ব্যবহার করা হয়েছে যাতে ডেটা লোড করা হয় এবং UI থ্রেডে কোনো ইস্যু না হয়।


সারাংশ

Complex Queries এবং Projection Entity Framework এ খুব শক্তিশালী কৌশল, যেগুলি আপনাকে জটিল ডেটাবেস কুয়েরি করার ক্ষমতা দেয় এবং নির্দিষ্টভাবে প্রয়োজনীয় তথ্য রিটার্ন করার সুবিধা দেয়। আপনি LINQ ব্যবহার করে সহজেই এই কৌশলগুলো প্রয়োগ করতে পারেন এবং ডেটাবেস থেকে দক্ষতার সাথে প্রয়োজনীয় ডেটা আহরণ করতে পারেন।

common.content_added_by
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion